<template>
  <div class="user-edit-container">
    <!-- Header 区域 -->
    <van-nav-bar title="编辑资料" left-arrow @click-left="$router.back()" fixed />

    <!-- 用户资料 -->
    <van-cell-group class="action-card">
      <van-cell title="头像" is-link center>
        <template #default>
          <van-image round class="avatar" :src="profileObj.photo" @click="imageClickFn"/>
          <!-- file 选择框 -->
               <input
               type="file"
               ref="iptFile"
               v-show="false"
               accept="image/*"
               @change="onFileChange"
               />
        </template>
      </van-cell>
      <van-cell title="名称" is-link  :value="profileObj.name" @click="nameClickFn"/>
      <van-cell title="生日" is-link  :value="profileObj.birthday" @click="birthdayClickFn"/>
    </van-cell-group>
    <!-- 姓名修改弹窗 -->
    <van-dialog v-model="show" title="修改名称" show-cancel-button :before-close="beforeCloseFn">
      <input type="text" v-model="inputUserName" v-fofo>
</van-dialog>
<van-popup v-model="dataTimeShow" position="bottom" :style="{ height: '50%' }" round >
    <!-- 事件选择器 -->
    <van-datetime-picker
    v-model="currentDate"
    type="date"
    title="选择年月日"
    :min-date="minDate"
    :max-date="maxDate"
    @cancel="detaCancelFn"
    @confirm="confirmFn"
/>
</van-popup>
  </div>
</template>

<script>
import {userProfileAPI,updateUserPhotoAPI,updateUserProfileAPI} from '@/api/index'
import {Notify} from 'vant'
import {formatDate} from '@/utils/date'
export default {
  name: 'UserEdit',
  data () {
    return {
        profileObj: {}, // 用户基本资料
        show: false, // 控制姓名输入框的显示或隐藏
        inputUserName: '', // 修改名字 - 弹出框输入框绑定值
        minDate: new Date(1980, 0, 1), // 最小范围
        maxDate: new Date(), // 最大范围 (默认显示当前时间)
        currentDate: new Date(2022, 0, 17), // 当前时间
        dataTimeShow: false, 
    }
  },
  async created () {
    const res = await userProfileAPI()
    console.log(res)
    this.profileObj = res.data.data
  },
  methods: {
    // 文件选择改变 - 事件
   async onFileChange (e) {
        if (e.target.files.length === 0) return // 用户可能没有选择图片文件阻止代码往下
        console.log(e.target.files[0]) // 数组其实是一个特殊的对象
        // 创建FormData对象
        const theFd = new FormData()
        theFd.append('photo',e.target.files[0]) // 请求体里加入一对参数名和值
        try {
            const res = await updateUserPhotoAPI(theFd)
            console.log(res)
            // 局部刷新头像
            this.profileObj.photo = res.data.data.photo
            Notify({ type: 'success', message: '修改成功' });
        } catch {
            Notify({ type: 'warning', message: '修改失败' });
        }
    },
    // 图片 - 点击事件
    imageClickFn () {
        this.$refs.iptFile.click() // JS魔力标签的事件触发
    },
    // 姓名 - 点击事件
    nameClickFn () {
      this.show = true
      this.inputUserName = this.profileObj.name
    },
    // 姓名 - 确认框 - 关闭前回调函数
   async beforeCloseFn (action,done) {
      if (action === 'confirm') {
        // 点确定
        const reg = /^[A-Za-z0-9\u4e00-\u9fa5]{1,7}$/
        if (reg.test(this.inputUserName) === true) {
          // 通过校验
          await updateUserProfileAPI({
            name: this.inputUserName
          })
          this.profileObj.name = this.inputUserName // 更新成功 - 回显到页面上
          Notify({type: 'success', message: '修改成功'})
          done()
        } else {
          // 没通过校验,给用户提示
          Notify({type: 'warning',message: '用户名只能是1-7位中英数字组合'})
          done(false)
        }
      } else {
        // 点取消
        done() // 让弹窗关闭
      }
    },
    // 生日单元格 - 点击事件
    birthdayClickFn () {
      this.dataTimeShow = true // 日期选择器出现
      // 数据和页面显示 ->  年-月-日 格式的字符串
      this.currentDate = new Date(this.profileObj.birthday)
    },
    // 日期选择器 - 取消事件
    detaCancelFn () {
      this.dataTimeShow = false 
    },
    // 日期选择器 - 完成确认事件
    async confirmFn () {
      // 日期选择器组件里currentDate是日期对象,而后端要的是年月日
      await updateUserProfileAPI({
        birthday: formatDate(this.currentDate)
      })
      this.dataTimeShow = false
      this.profileObj.birthday = formatDate(this.currentDate) // 同步单元格
      Notify({type: 'success',message: '修改成功'})
    }
  }
}
</script>

<style lang="less" scoped>
.user-edit-container {
  padding-top: 46px;
  .avatar {
    width: 50px;
    height: 50px;
  }
}

::v-deep .van-dialog__content {
  text-align: center;
  input {
    padding: 0;
    outline: none;
    border: none;
    text-align: center;
  }
}
</style>
